-
Notifications
You must be signed in to change notification settings - Fork 273
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix: Prevent newExporter crash if tree.ndb is nil #622
fix: Prevent newExporter crash if tree.ndb is nil #622
Conversation
export.go
Outdated
} | ||
// CV Prevent crash on incrVersionReaders if tree.ndb == nil | ||
if tree.ndb == nil { | ||
fmt.Printf("iavl/export newExporter failed to create because tree.ndb is nil\n") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this function should return error. Doing fmt.Printf
doesn't make sense here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
agree, lets break the api.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could just return (nil, err) with fmt.Errorf to start with. Then any more complicated error handling can be followed up in other commits/improvment?
Or is there some error standard you're trying to maintain?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yea that makes sense, we would then handle this in the application
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Returning error now, updated api/test
Last commit returns explicit error as recommended. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm, added one suggestion
export.go
Outdated
} | ||
// CV Prevent crash on incrVersionReaders if tree.ndb == nil | ||
if tree.ndb == nil { | ||
return nil, ErrorTreeNodeDbNil |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
maybe we can have one error type: ErrNotIniitalizedTree
. And then use wrapping to add more details, eg:
ErrNotIniitalizedTree.Wrap("ndb is nil")
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wrapped
change log updated, errors wrapped |
note change in errors package |
export.go
Outdated
func newExporter(tree *ImmutableTree) *Exporter { | ||
func newExporter(tree *ImmutableTree) (*Exporter, error) { | ||
if tree == nil { | ||
return nil, errors.Wrap(ErrNotInitalizedTree, "tree is nil") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we use fmt.Errorf to avoid introducing GitHub.com/pkg/errors as a dependency
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
My mistake. I thought the team was looking to call Wrap() specifically. Will change it again.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
no worries, pkg/errors is deprecated with go 1.18 and beyond because of fmt.errorf and/or errors pkg.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Learn something new every day
Updated : change from requested Wrap to fmt.Errorf |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thank you for submitting this!!! we can look at back porting this to avoid the issues being seen.
linting and tests are failing, could you fix and we will handle backport |
Will give it a shot and let you know if help is required :) |
Issue was hiding in the benchmarks, fixed and running through tests. |
looks like there's some fumpting to do (sorry not yet completely familiar with all the tests in this repo) |
went fumpting |
Also as a note, noticed:
But in Makefile it still tries to build iavlserver
Want it removed? |
Removed failing build of cmd/iavlserver. Let me know if you want it back. |
thanks for the pr @chillyvee |
@Mergifyio backport release/v0.19.x |
@Mergifyio backport release/v0.19.x |
✅ Backports have been created
|
Co-authored-by: Marko <[email protected]> (cherry picked from commit 2777659) # Conflicts: # export.go
Co-authored-by: Chill Validation <[email protected]> Co-authored-by: Marko Baricevic <[email protected]>
…osmos#622) (cosmos#631)" This reverts commit 2af006a.
…osmos#622) (cosmos#631)" This reverts commit 2af006a.
… (cosmos#631) Co-authored-by: Chill Validation <[email protected]> Co-authored-by: Marko Baricevic <[email protected]>
v0.19.5 + cosmos/iavl#622
Found a case where dig chain did not have all stores configured with a nodedb (for whatever reason)
It is better to return an error so that cosmos-sdk can determine whether to skip the misconfigured store or panic.
Would also like to backport to fix v0.19.4 (but need assistance to target the right branch)